REST: harden guest author username collision handling#177
Draft
dknauss wants to merge 1 commit intohumanmade:developfrom
Draft
REST: harden guest author username collision handling#177dknauss wants to merge 1 commit intohumanmade:developfrom
dknauss wants to merge 1 commit intohumanmade:developfrom
Conversation
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Guest author creation should not fail just because two people share the same normalized name or because a display name (e.g., with non-ASCII characters) normalizes to an empty username. This patch keeps the existing endpoint contract intact while making username generation deterministic, resilient, and easier to reason about in real-world editorial workflows.
Summary
Harden guest author creation so generated usernames remain valid and unique when names collide or normalize to an empty value.
What changed
guestauthorwhen normalization produces an empty usernameWhy
The current guest-author create path assumes the first generated username is
usable. In practice, valid guest-author requests can collide with an existing
username or normalize to an empty string.
This change makes guest-author creation deterministic and more resilient without changing the endpoint contract.
Scope
This PR is intentionally narrow and limited to guest-author username generation.
Included:
inc/class-users-controller.phptests/phpunit/test-rest-api-user-endpoint.phpNot included:
Verification
vendor/bin/phpunit --filter TestRESTAPIUserEndpointphp -l inc/class-users-controller.phpphp -l tests/phpunit/test-rest-api-user-endpoint.php